/*
 *      Copyright (c) 2018-2028, Chill Zhuang All rights reserved.
 *
 *  Redistribution and use in source and binary forms, with or without
 *  modification, are permitted provided that the following conditions are met:
 *
 *  Redistributions of source code must retain the above copyright notice,
 *  this list of conditions and the following disclaimer.
 *  Redistributions in binary form must reproduce the above copyright
 *  notice, this list of conditions and the following disclaimer in the
 *  documentation and/or other materials provided with the distribution.
 *  Neither the name of the dreamlu.net developer nor the names of its
 *  contributors may be used to endorse or promote products derived from
 *  this software without specific prior written permission.
 *  Author: Chill 庄骞 (smallchill@163.com)
 */
package org.springblade.mach.controller;

import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
import lombok.AllArgsConstructor;

import javax.servlet.http.HttpServletResponse;
import javax.sql.rowset.serial.SerialException;
import javax.validation.Valid;

import org.springblade.core.excel.util.ExcelUtil;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.Func;
import org.springblade.mach.excel.StandardPartsExcel;
import org.springblade.mach.excel.StandardPartsImporter;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.bind.annotation.RequestParam;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springblade.mach.entity.StandardParts;
import org.springblade.mach.vo.StandardPartsVO;
import org.springblade.mach.wrapper.StandardPartsWrapper;
import org.springblade.mach.service.IStandardPartsService;
import org.springblade.core.boot.ctrl.BladeController;
import org.springframework.web.multipart.MultipartFile;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;

/**
 * 标准件库表 控制器
 *
 * @author ly
 * @since 2021-04-22
 */
@RestController
@AllArgsConstructor
@RequestMapping("data-standard/standardparts")
@Api(value = "标准件库表", tags = "标准件库表接口")
public class StandardPartsController extends BladeController {

	private final IStandardPartsService standardPartsService;
	/**
	 * 导出excel模板中得数据
	 * 代码、名称、数量、材料、备注
	 */
	@GetMapping("export-template")
	public void exportStandardParts(HttpServletResponse response){
		List<StandardPartsExcel> list = new ArrayList<>();
		ExcelUtil.export(response,"国标件物料信息导入模板","sheet1", list, StandardPartsExcel.class);
	}
	/**
	 * 导入excel表格中的数据
	 */
	@PostMapping("import-standard-parts")
    public R importStandardParts(MultipartFile file, Integer isCovered){
		StandardPartsImporter standardPartsImporter = new StandardPartsImporter(standardPartsService, isCovered == 1);
		ExcelUtil.save(file, standardPartsImporter, StandardPartsExcel.class);
        return R.success("操作成功");
	}

	/**
	 * 详情
	 */
	@GetMapping("/detail")
	@ApiOperationSupport(order = 1)
	@ApiOperation(value = "详情", notes = "传入standardParts")
	public R<StandardPartsVO> detail(StandardParts standardParts) {
		StandardParts detail = standardPartsService.getOne(Condition.getQueryWrapper(standardParts));
		return R.data(StandardPartsWrapper.build().entityVO(detail));
	}

	/**
	 * 分页 标准件库表
	 * 查询为模糊查询：Map
	 */
	@GetMapping("/list")
	@ApiOperationSupport(order = 2)
	@ApiOperation(value = "分页", notes = "传入standardParts")
	public R<IPage<StandardPartsVO>> list(@RequestParam Map<String,Object> standardParts, Query query) {
		IPage<StandardParts> pages = standardPartsService.page(Condition.getPage(query),
			Condition.getQueryWrapper(standardParts,StandardParts.class).
				lambda().
				orderByDesc(StandardParts::getCreateTime));
		return R.data(StandardPartsWrapper.build().pageVO(pages));
	}


	/**
	 * 自定义分页 标准件库表
	 */
	@GetMapping("/page")
	@ApiOperationSupport(order = 3)
	@ApiOperation(value = "分页", notes = "传入standardParts")
	public R<IPage<StandardPartsVO>> page(StandardPartsVO standardParts, Query query) {
		IPage<StandardPartsVO> pages = standardPartsService.selectStandardPartsPage(Condition.getPage(query), standardParts);
		return R.data(pages);
	}

	/**
	 * 新增 标准件库表
	 */
	@PostMapping("/save")
	@ApiOperationSupport(order = 4)
	@ApiOperation(value = "新增", notes = "传入standardParts")
	public R save(@Valid @RequestBody StandardParts standardParts) throws SerialException {
		return R.status(standardPartsService.saveCheck(standardParts));
	}

	/**
	 * 修改 标准件库表
	 */
	@PostMapping("/update")
	@ApiOperationSupport(order = 5)
	@ApiOperation(value = "修改", notes = "传入standardParts")
	public R update(@Valid @RequestBody StandardParts standardParts) {
		return R.status(standardPartsService.updateById(standardParts));
	}

	/**
	 * 新增或修改 标准件库表
	 */
	@PostMapping("/submit")
	@ApiOperationSupport(order = 6)
	@ApiOperation(value = "新增或修改", notes = "传入standardParts")
	public R submit(@Valid @RequestBody StandardParts standardParts) {
		return R.status(standardPartsService.saveOrUpdate(standardParts));
	}


	/**
	 * 删除 标准件库表
	 */
	@PostMapping("/remove")
	@ApiOperationSupport(order = 7)
	@ApiOperation(value = "逻辑删除", notes = "传入ids")
	public R remove(@ApiParam(value = "主键集合", required = true) @RequestParam String ids) {
		return R.status(standardPartsService.deleteLogic(Func.toLongList(ids)));
	}


}
